<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="../css/reset.css">
    <style>
        .wrap {
            margin-top: 50px;
        }

        nav {
            width: 600px;
            display: flex;
            line-height: 40px;
            text-align: center;
            margin: 0 auto;
        }

        nav li {
            flex: 1;
            border: 1px solid #333;
        }

        /* nav li+li {
            border-left: 0;
        } */
        nav li:not(:first-child) {
            border-left: 0;
        }

        nav .active {
            background-color: #6ff;
            color: #fff;
        }
    </style>
</head>

<body>
    <div class="wrap">
        <nav>
            <li>01</li>
            <li>02</li>
            <li>03</li>
            <li>04</li>
            <li>05</li>
            <li>06</li>
        </nav>
    </div>
</body>
<script>
    // 导航栏切换 
    // 点击每一个li =>   当前li 背景颜色变天蓝色 字体变白色

    // 方法1: 先清除上一个活跃状态  在把当前元素变为活跃状态 => 记录被点击元素的下标,下次清除时使用


    var liList = document.querySelectorAll("nav li");
    console.log(liList);

    var prevIndex = null;  // 全局变量 记录被点击的元素的下标

    for (var i = 0; i < liList.length; i++) {
        var li = liList[i]; // 遍历每个li
        li.setAttribute("data-index", i);
        li.onclick = function () { //给遍历的li绑定事件

            if (prevIndex) {  // 如果存在被点击的元素  => 对应下标清除
                liList[prevIndex].className = "";
            }
            this.className = "active";  //当前被点击的元素 变为活跃状态

            prevIndex = this.dataset.index; // 记录被点击的元素的下标 => 下次清除时使用

        }
    }
    console.log("页面加载完毕:", li, i);



</script>

</html>